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1 . Claims 1 -36 have been examined. 

Acknowledgment of papers filed: amendment and remarks filed on May 26 th , 
2006. The papers filed have been placed on record. 



Specification 

2. The title is not descriptive. A new title is required that is clearly indicative of the 
invention to which the claims are directed. 

Claim Objections 

3. Claim objection is withdrawn with regards to the amendment of claim 26. 



Claim Rejections - 35 USC § 101 

4. * 35 U.S.C. 101 reads as follows: 

Whoever invents or discovers any new and useful process, machine, manufacture, or composition of 
matter, or any new and useful improvement thereof, may obtain a patent therefor, subject to the 
conditions and requirements of this title. 

.Claims 10-18 are rejected under 35 U.S.C. 101 because the claimed invention is 
directed to non-statutory subject matter. In paragraph 36 of the specification, a 
"propagated signal" is given as an example as an information carrier. This signal 
appears to be within the bounds of the claimed term "machine-readable medium". The 
term "machine-readable storage device" is suggested. 
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Claim Rejections - 35 USC § 103 

5. The following is a quotation of 35 U.S.C. 103(a) which forms the basis for all 
obviousness rejections set forth in this Office action: 

(a) A patent may not be obtained though the invention is not identically disclosed or described as set 
forth in section 102 of this title, if the differences between the subject matter sought to be patented and 
the prior art are such that the subject matter as a whole would have been obvious at the time the 
invention was made to a person having ordinary skill in the art to which said subject matter pertains. 
Patentability shall not be negatived by the manner in which the invention was made. 

6. Claim 34 is rejected under 35 U.S.C. 103(a) as being unpatentable over 
Thekkath in view of TMS32010 User's Guide (herein TMS). 

7. Regarding claim 34, Thekkath discloses a processor comprising: an engine 
having an instruction set including an instruction having a syntax that specifies a logical 
operation on a condition code (Table col 10 1 line 40-43) determined by executing a 
instruction (col 4 lines 19-21) 

Note that the suggestion of a comparison implies an instruction used to create 
the condition codes. 

And on another condition code determined from a previously executed instruction 
(col 1 table 10 lines 40-43). 

8. Thekkath fails to disclose the logical operation and condition setting within the 
same instruction. 

TMS32010 User's Guide discloses the simple technique of combining two 
instructions into a single clock cycle (page 3-7 mnemonic LTA). 
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During the design of a processor, many factors need to be considered when 
creating an instruction set. Essentially, the idea is to allow as many computations as 
possible to occur during a single clock cycle, while keeping the clock frequency as short 
as possible. Keeping this in mind, depending on how the weight of both those 
opposing factors are evaluated, a designer would have adequate motivation to either 
combine or separate a group of computations into one or two instructions. 

It would have been obvious at the time of the invention for one of ordinary skill in 
the art to take the computing system of Thekkath and combine the conditional jump 
instructions disclosed in col 10 table 1 lines 41-42 to be combined with the compare 
instruction that sets the condition code, causing them to both occur during the same 
clock cycle. 

9. Claims 1-6, 8-15, 17-24, 26-33 and 35-36 are rejected under 35 U.S.C. 103(a) as 
being anticipated by Thekkath (U.S. Patent No. 6,732,259) in view TMS32010 User's 
Guide (herein TMS) in further view of Anderson (U.S. Patent No. 6,005,860). 

10. Regarding claim 1 , Thekkath discloses a method of executing instructions on a 
processor (col 10 table 1), the method comprising: receiving a first condition code 
produced by executing a first instruction (col 4 lines 19-21) 

Note that the suggestion of a comparison implies an instruction used to create 
the condition codes. 

During a first clock cycle (see below) 
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Note that logical computer systems are "black and white" in their analysis of 
information. A condition code is changed (produced) during a single and distinct clock 
cycle. This is considered to be "a first clock cycle". 

Receiving a second condition code (col 10 table 1 lines 41-42) 

Note that the listed instructions require two condition codes. 

Produced by executing a second instruction during a second clock cycle (see 

below) 

The "second instruction" and "second clock cycle" exist based on the same 
analysis as the "first instruction" during the "first clock cycle". See above. 

And executing a logical operator (col 10 table 1 lines 41-42) 

Note that, for instruction BC1ANY2F for example, if "either one of two 
consecutive condition codes are false" suggests the use of a logical OR operator. 

On the first and second condition codes (col 10 table 1 lines 41-42). 

1 1 . Thekkath fails to disclose the conditional branch instruction and the second 
condition code setting instruction to be during the same clock cycle. 

TMS32010 User's Guide discloses the simple technique of combining two 
instructions into a single clock cycle (page 3-7 mnemonic LTA). 

During the design of a processor, many factors need to be considered when 
creating an instruction set. Essentially, the idea is to allow as many computations as 
possible to occur during a single clock cycle, while keeping the clock frequency as short 
as possible. Keeping this in mind, depending on how the weight of both those 
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opposing factors are evaluated, a designer would have adequate motivation to either 
combine or separate a group of computations into one or two instructions. 

It would have been obvious at the time of the invention for one of ordinary skill in 
the art to take the computing system of Thekkath and combine the conditional jump 
instructions disclosed in col 10 table 1 lines 41-42 to be combined with the compare 
instruction that sets the second conditional condition, causing them to both occur during 
the same clock cycle. 

12. Thekkath/TMS/Anderson fail to disclose an array of engines included in the 
processor. 

Anderson discloses the technique of multithreading (col 4 lines 16-20). 

As stated in Anderson, "Those skilled in the art will appreciate the need for real- 
time, multithreaded performance in information retrieval applications in order to support 
an adequate level of transactional performance" (col 10 lines 36-39). Additionally, it is 
well known in the art that the technique of multithreading can be used to dramatically 
improve processor performance. 

It would have been obvious at the time of the invention for one of ordinary skill in 
the art to add an array of engines (or multithreading capabilities) as in Anderson to the 
computing system of Thekkath/TMS/Anderson. 
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13. Regarding claims 2, 1 1, 20, 29, and 32 Thekkath/TMS/Anderson discloses the 
method of claim 1 (and necessary independent claims), wherein executing the logical 
operator includes executing a logical "AND" operation (Thekkath col 9 lines 62-65). 

Note that there are at least three variables involved in determining whether a 
branch is taken with regard to instructions BC1ANY2F and BC1ANY2T. There are the 
two condition codes and the T/F (depending on which instruction is used). Logically, 
based on standard hardware simplification, these variables are reduced to 
X(0)*C1(0)+C1*C2(0)+X*C2, where anXis the true/false variable, C1 and C2 represent 
the first and second condition codes, respectively, and the (0) the requirement of a zero 
value (rather than a one). Also, as with standard shorthand, + indicates an OR and * 
indicates an AND. This means that, at a minimum, both a logical OR and AND are 
required for both of these instructions to be in the instruction set. 

14. Regarding claims 3, 12, 21 , 30 and 33, Thekkath/TMS/Anderson discloses the 
method of claim 1 (and necessary independent claims), wherein executing the logical 
operator includes ignoring the first condition code (Thekkath Table col 10 1 line 40-43). 

Note that a reasonable definition of "ignoring" within a logical computer science 
standpoint, would be to find a situation in which the outcome of the logical operation is 
not affected by the input of the first condition code. In hardware logic, this is often 
called a "don't care" bit. Consider the situation where BC1ANY2F instruction is used, 
and the second condition code is false. In this circumstance, either input of the first 
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condition code would not affect the outcome of the instruction. This would make the 
first condition code a "don't care bit" and, in essence, ignored. 

15. Regarding claims 4, 13 and 22, Thekkath/TMS/Anderson discloses the method of 
claim 1 (and necessary independent claims), wherein executing the logical operator 
includes ignoring the second condition code (Thekkath Table col 10 1 line 40-43). 

Note: see claim 3, but consider the situation that a BC1ANY2F instruction is used 
and the first condition code is false. 

16. Regarding claims 5, 14 and 23, Thekkath/TMS/Anderson discloses the method of 
claim 1 (and necessary independent claims), wherein the first instruction is executed on 
one engine within the array of engines included in the processor (see below). 

Note that this is an accurate description of how a multi-threaded system would 
handle the first instruction. The first instruction, being a single instruction, would be 
executed by a single thread or "one engine". Also note that the disclosure of "one 
engine" does not limit against the use of additional engines from the execution of this 
instruction. 

17. Regarding claims 6, 15, and 24, Thekkath/TMS/Anderson discloses the method 
of claim 1 (and necessary independent claims), wherein the first condition code 
indicates if the execution of the first instruction produced a numerical zero (Thekkath col 
10 lines 40-43). 
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Note that for these instructions to determine if a condition code is true or false, 
the condition code must have some way to indicate whether or not it has a value of 
zero. 

18. Regarding claims 8, 17 and 16, Thekkath/TMS/Anderson discloses the method of 
claim 1. 

Thekkath/TMS/Anderson (as previously combined) fails to disclose the first 
condition code including data for determining a destination of a data packet. 

Anderson discloses the technique of packet routing (col 4 lines 4-8). 

The technique of packet routing is very common for the communication of 
processing units. The destination of packets to be routing must depend on some series 
of conditions, otherwise a router would not be needed. The technique used in Thekkath 
of using multiple condition codes could be used with a further application of packet 
routing. Thekkath would be motivated to use this already developed technique for 
packet routing. 

It would have been obvious at the time of the invention for one of ordinary skill in 
the art to utilize the technique of packet routing from Anderson with the system of 
Thekkath/TMS/Anderson as previously combined. 

19. Regarding claims 9, 18 and 27, Thekkath discloses the method of claim 1, 
wherein a third instruction is executed by the array of engines prior to executing the 
second instruction (col 10 table 1). 
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Note that table 1 lists a variety of instructions, each of which the processor is 
capable of processing. The invention in the reference is clearly able to execute a "third 
instruction" prior to executing the second instruction. 

20. Regarding claim 10, Thekkath/TSM/Anderson discloses the limitations common 
to claim 1 as well as a computer program product, tangibly embodied in an information 
carrier, for executing instructions on a processor (see below). 

Note that the instructions on col 10 table 1 lines 40-43 listed in a program 
(among other possible instructions) are considered to be the "computer program 
product". Whatever registers or memory containing that program for execution is 
considered to be the information carrier 

21 . Regarding claim 1 9, Thekkath/TSM/Anderson discloses the limitations common 
to claim 1 . 

Thekkath/TSM/Anderson (as previously combined) does not disclose a packet 
classifier. See claim 8 for combination and motivation regarding the packet classifier. 

22. Regarding claim 26, Thekkath/TSM/Anderson discloses the packet-classifier of 
claim 19, wherein the first condition code includes data for determining a destination of 
a data packet (col 4 lines 16-20). 
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23. Regarding claim 28, Thekkath/TSM/Anderson discloses the limitations common 
to claim 1 as well as a system comprising a processor (Thekkath col 3 lines 42-47) 

24. Regarding claim 31, Thekkath/TSM/Anderson discloses the limitations common 
to claim 1 as well as a router with an input port and output port determined by a 
switching fabric (see claim 8 for combination and motivation). 

Note that the router, with the ability to route packets depending on conditions 
clearly has inputs and outputs. Additionally, whatever logic is involved in making the 
destination determination based on condition codes is considered to be a "switching 
fabric". 

25. Regarding claim 35, Thekkath discloses the processor of claim 34, wherein the 
processor includes a second engine. See claim 1 for combination and motivation for 
multithreading (considered to be a second engine). 

26. Regarding claim 36, Thekkath discloses the processor of claim 34, wherein the 
engine is multithreaded (Anderson col 10 lines 34-39). 

27. Claims 7, 16, and 25 are rejected under 35 U.S.C. 103(a) as being unpatentable 
over Thekkath/TMS/Anderson in view of Sun (U.S. Patent No. 6,772,370). 
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28. Regarding claims 7 16, 25 and 26, Thekkath/TMS/Anderson discloses the 
method of claim 1 . 

Thekkath/TMS/Anderson fails to disclose a condition code that indicates if the 
execution of the first instruction produced an overflow. 

Sun discloses an overflow condition code (col 9 line 9). 

Within many applications of condition codes (including both packet routing and 
branching) having condition codes that allow for a complete coverage of exception 
situations is essential for a processor's correct functionality during an exception. Not 
surprisingly, "prior art attempts to detect hazard conditions" (Sun col 1 lines 54). 
Overflow, a more typical conditional exception, would be an obvious addition to a set of 
condition codes that affect the result of a branch or packet routing (for example, a 
branch may branch to an instruction service routine or a packet may be routed to a 
holding queue until exceptions are resolved). In either case, one would be motivated to 
include this overflow condition in order to "provide the flexibility, accuracy, or 
completeness of coverage desired" (Sun col 1 lines 56-57). 

It would have been obvious at the time of the invention for one of ordinary skill in the art 
to include an overflow condition instruction (as in Sun) within the computing system of 
Thekkath/TMS/Anderson in order to allow the conditional branch/routing utilize said 
overflow condition. 



Response to Arguments 
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29. Applicant's arguments filed May 26 th , 2006 have been fully considered but they 
are not persuasive. 

30. Applicant states: 

"The title was objected to as being non-descriptive. Without conceding the examiner's position, 
the title has been amended. " 

Examiner asserts that the title is still non-descriptive. The amendment to the title 
stating that the processor is multi-threaded a good start; however, the title still fails to 
distinguish the intention for the many hundreds of additional patents that disclose 
executing instructions on a multithreaded processor. Please amend the title once more 
to give the reader a good idea of the particular presumed novelty of Applicant's 
invention. 

31. Applicant states: 

"Claims 10-18 were rejected under 35 U.S.C. 101 as directed to non-statutory subject matter. 
Claim 10 has been amended to call for 'a computer program product, tangibly embodied in a machine- 
readable medium, for executing instructions on a processor, the computer program product being 
operable to cause a machine to...'. As amended claim 10 now claims a machine-readable medium with 
is an article of manufacture. " 

Examiner disagrees. Examiner recommends changing the term "machine- 
readable medium" to a "machine-readable storage device" that is clearly distinguished 
in Applicant's specification from the "propagated signal". 

32. Applicant state: 

"Even if TMS describes combining two actions into a signle instruction that may be executed in a 
single clock cycle, TMS fails to disclose an instruction set including an instruction that specifies 'a 
condition code determined by executing the instruction' and 'a logical operation on [that] condition 
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code. . .and on another condition code' as recited in claim 34. Executing multiple unrelated actions using 
a single instruction in a single clock cycle does not teach or suggest determining a condition code and 
performing a logical operation on that condition code and another condition code within the same clock 
cycle. TMS does not disclose or would not have made obvious 'an instruction set including an instruction 
having a syntax that specifies a logical operation on a condition code determined by executing the 
instruction' as recited in claim 34. Claim 34 is patentable for at least this reason. " 

Examiner disagrees. Applicant argues that TMS does not disclose or make 
obvious all limitations of claim 34. Examiner agrees with statement. For this reason, 
Examiner rejected this claim under 35 USC 103 using two references. The combination 
does, in fact, disclose all limitations of claim 34. 



Conclusion 

33. THIS ACTION IS MADE FINAL. Applicant is reminded of the extension of time 
policy as set forth in 37 CFR 1.136(a). 

A shortened statutory period for reply to this final action is set to expire THREE 
MONTHS from the mailing date of this action. In the event a first reply is filed within 
TWO MONTHS of the mailing date of this final action and the advisory action is not 
mailed until after the end of the THREE-MONTH shortened statutory period, then the 
shortened statutory period will expire on the date the advisory action is mailed, and any 
extension fee pursuant to 37 CFR 1.136(a) will be calculated from the mailing date of 
the advisory action. In no event, however, will the statutory period for reply expire later 
than SIX MONTHS from the mailing date of this final action. 

Any inquiry concerning this communication or earlier communications from the 
examiner should be directed to Brian P. Johnson whose telephone number is (571) 272- 
2678. The examiner can normally be reached on 8-4:30 M-F. 
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If attempts to reach the examiner by telephone are unsuccessful, the examiner's 
supervisor, Eddie Chan can be reached on (571) 272-4162. The fax phone number for 
the organization where this application or proceeding is assigned is 571-273-8300. 

Information regarding the status of an application may be obtained from the 
Patent Application Information Retrieval (PAIR) system. Status information for 
published applications may be obtained from either Private PAIR or Public PAIR. 
Status information for unpublished applications is available through Private PAIR only. 
For more information about the PAIR system, see http://pair-direct.uspto.gov. Should 
you have questions on access to the Private PAIR system, contact the Electronic 
Business Center (EBC) at 866-217-9197 (toll-free). If you would like assistance from a 
USPTO Customer Service Representative or access to the automated information 
system, call 800-786-9199 (IN USA OR CANADA) or 571-272-1000. 




